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TITLE OF THE INVENTION 
HIERARCHICAL PACKET SCHEDULING METHOD AND APPARATUS 



CROSS REFERENCE TO RELATED APPLICATIONS 
This application claims, priority under 35 U.S.C. § 
119(e) to provisional patent application serial number 
60/042,943 filed April 4, 1997. 

STATEMENT REGARDING FEDERALLY SPONSORED RESEARCH OR 

DEVELOPMENT 
Not Applicable 

15 BACKGROUND OF THE INVENTION 

In any single scheduler methodology, such as the Packet 
Fair Queuing (PFQ) class of schedulers (described below) 
which include Virtual Clock (VC) , Self-Clocked Fair Queuing 
(SCFQ) , Start-time Fair Queuing (STFQ) , Minimum Start Time 
Clocked Fair Queuing Plus (MSTCFQ + ) , Deficit Round Robin Fair 
Queuing (DRRFQ) , Packetized Generalized Processor Sharing 
(PGPS) , Worst Case Fair Weighted Queuing (WF 2 Q) and Worst- 
case Fair Weighted Fair Queuing Plus (WF 2 Q+) the scheduler is 
unable to fairly and efficiently handle a plurality of 
diverse traffic types or sessions. 

VC schedulers monitor the average transmission rate of 
statistical data flows and provides every flow with a 
guaranteed throughput. Each user requests an allocation for 
the amount of traffic the user expects. The packets are then 
time stamped and placed in a queue according to the value of 
their time stamp. VC schedulers have a tight delay bound 
that is independent of the number of sessions involved in 
order to provide for delay minimization. However, VC 
schedulers do not allocate available bandwidth as fairly as 
35 other schedulers. 
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Self Clocked Fair Queuing (SCFQ) schedulers as well as 
Start Time Fair Queuing (STFQ) schedulers have a high degree 
of fairness for allocating bandwidth. However, they do not 
have the desired delay minimization since the virtual time 
is not strictly monotonically increasing, their delay bounds 
are proportional to the number of sessions involved. 

The MSTCFQ+ scheduler determines the virtual finish time 
of the packet by determining the transfer time required for 
the packet from its length and transfer rate, and adds this 
transfer time to the virtual start time of the packet. The 
packet with the smallest virtual finish time is then 
scheduled for transfer. The MSTCFQ+ scheduler provides an 
effective tradeoff between performance and complexity as 
compared to other schedulers. 

DRRFQ schedulers have a high degree of fairness but are 
less effective when load balancing or distributed queues are 
used. 

The WF 2 Q and WF 2 Q+ schedulers have both a high degree of 
fairness and also the desired delay minimization. Therefore 
the WF 2 Q and WF 2 Q+ schedulers are not only fair but also have 
a tight delay bound that is independent, of the number of 
sessions involved. However, the implementation costs of WF 2 Q . 
and WF 2 Q+ schedulers are high compared to other schedulers 
, since the WF 2 Q and WF 2 Q+ schedulers must perform two searches 
25 on each session; one search to determine the packet start 

times of the first packet in each session, and a second 
search to determine the packet start times of all backlogged 
packets in each session; whereas other schedulers typically 
perform a single search on the first packet of each session 
for determining the packet start times. 

PGPS schedulers are similar to the WF 2 Q and WF 2 Q + 
schedulers, especially when utilizing packets having a small 
packet size, however the PGPS • scheduler is better at 
minimizing worst-case session delay. 

The diverse sessions provided to the scheduler may 
comprise voice, video or data transmissions, each having 
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different Quality of Service (QoS) requirements and 
characteristics. There exists six classes regarding the QoS 
of traffic on networks such as an Asynchronous Transfer Mode 
(ATM) network. These six classes are Constant Bit Rate 
(CBR) , real time Variable Bit Rate (rtVBR) , non-real time 
Variable Bit Rate (nrtVBR) , Available Bit Rate (ABR) , 
Unspecified Bit Rate Plus (UBR+) and Unspecified Bit Rate 
(UBR) . Each QoS class has different requirements which must 
be taken into account by the scheduler in order to provide 
the maximum efficiency for handling this class of traffic. 
As an example, the CBR class is typically used for high 
quality video, the rtVBR class for voice and video, the 
nrtVBR class for low-quality video, the ABR class for data 
with flow control, the UBR+ class for data with no flow 
control and the UBR class for low priority data such as E- 
mail . 

Networks such as ATM networks are becoming more 
sophisticated and are expected to handle multiple connections 
organized as distinct sessions with various QoS requirements. 
It would be desirable to have a scheduler which can be 
implemented in a cost effective manner and handle the QoS 
requirements of different sessions fairly and efficiently. 

BRIEF SUMMARY OF THE INVENTION 
A hierarchical scheduler includes a first level of 
schedulers that matches a plurality of sessions having 
various Quality of Service (QoS) requirements with different 
schedulers which are best suited for a particular QoS class. 
A second level scheduler then schedules the outputs from 
certain ones of the first level schedulers. A third level 
scheduler schedules the remaining^ outputs the first level 
schedulers with the outputs from the second level scheduler 
to provide a hierarchical scheduler output. The hierarchical 
scheduler apportions bandwidth among sessions having 
different requirements in a fair and efficient manner 
according to the QoS requirements of the respective sessions. 
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BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING 
The invention will be more fully understood from the 

following detailed description taken in conjunction with the 

accompanying drawings in which: 

Fig.' 1 is a block diagram of the hierarchical scheduler 

of the present invention; and 

Fig. 2 is a flow chart illustrative of the method 

employed in the hierarchical scheduler of the present 

invention. 

DETAILED DESCRIPTION OF THE INVENTION 
An hierarchical scheduler 10 in accordance with the 
present invention is shown in Fig. 1. The hierarchical 
scheduler 10 comprises an input 15, a first level of 
schedulers 17, a second level scheduler 80 and a third level 
scheduler 90 for providing an output 100. The input 15 
comprises packets from a plurality of sessions 12, 14, 16, 
18, 23 and 24 which have different operating characteristics. 

The input sessions are grouped into classes according to 
their Quality of Service (QoS) which will be described in 
greater detail below. A first level' of schedulers 17 
comprises different types of schedulers 20, 30', 40, 50, 60, 
and 70. The outputs of a group of the first level schedulers 
. 32, 42, 52, 62, and 72 are provided to a second level 
scheduler 80. The output of second level scheduler 80 is 
provided to a third level scheduler 90. The third level 
scheduler 90 also receives the output 22 of one of the first 
level schedulers 20. While one output from a first level 
scheduler is shown connected to the third level scheduler, 
it should be appreciated that any number of first level 
scheduler outputs could be connected to the third level 
scheduler, as well as any number of first scheduler outputs 
connected to the second level scheduler. The third level 
scheduler 90 provides an output 100. 

The presently disclosed hierarchical scheduler is 
particularly useful in an ATM network since the hierarchical 
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scheduler adapts the user traffic to the cell based network. 
The hierarchical scheduler supports different types of 
traffic at its input such as voice, video and data. The 
transmission requirements of voice, data and video are quite 
different, and each transmission type needs to be handled in 
a different manner in order to ensure the maximum efficiency 
and performance within such networks. 

Voice and low quality video transmissions can more 
readily handle errors. If a single voice or low quality 
video cell is distorted the quality of' the voice or video 
transmission is not severely affected, as long as the 
incidence of cell distortion is low and the flow is 
substantially continuous. In fact, a voice or video cell can 
occasionally be discarded without severely affecting the 
quality of the transmission. For example, cell loss of a 
duration up to approximately sixteen milliseconds is not very 
noticeable or disturbing to the listener or viewer. Voice 
and video transmissions must be substantially continuous 
despite the occasional distorted or discarded cell, and 
therefore require a short queue length in order to reduce 
delay. The short queue length can occasionally overflow with 
a resulting loss of packets. On the other hand, voice or 
video transmissions cannot tolerate excessive network delay 
since extensive delay may result in the voice or video 
transmission becoming incomprehensible to the listener or 
viewer. 

In contrast to voice and video transmissions, data 
transmissions have a low or zero tolerance for errors since 
one distorted bit can change substantially change the data. 
Conversely, data transmissions have a high tolerance for 
network delay. Accordingly, data transmissions require the 
queue lengths to be longer to prevent packet loss in an 
overflow condition. 

More specifically, the hierarchical scheduler need to 
provide session management in order to properly and 
efficiently manage the bandwidth of an ATM network. Each 
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session must be individually serviced by the hierarchical 
scheduler in a fair and equitable manner. Session servicing 
by the hierarchical scheduler must provide appropriate delays 
and acceptable traffic losses according to the 
5 characteristics and requirements of each of the sessions. 

The hierarchical scheduler assures that delay-sensitive 
sessions such as video sessions are serviced within 2 
milliseconds, that voice sessions are serviced so as not 
allow the loss of traffic to exceed 1 to 10 percent of the 
0 samples, and that data sessions should not experience any 

data loss. Additionally, not only do the ! characteristics 
among types of transmissions such as voice, video and data 
vary, but the characteristics within a transmission type 
itself may also vary. Accordingly, these differences also 
5 need to be taken into account by the hierarchical scheduler. 

For example, a conventional 64 kbits per second voice call 
operates at approximately 166 cells per second, while a 32 
kbits per second call operates at approximately 38 cells per 
second. For maximum fairness and efficiency these 

0 differences must also be considered. 

Referring again to Fig. 1, there exist six QoS traffic 
classes on ATM networks. These six classes are Constant Bit 
Rate (CBR) , real time Variable Bit Rate (rtVBR) , non-real 
.. time Variable Bit Rate (.nrtVBR) , Available Bit Rate (ABR) , 
5 ' Unspecified Bit Rate Plus (UBR+) and Unspecified Bit Rate 

(UBR) . Each QoS has different requirements which must be 
considered by a scheduler. 

The CBR class 12 has very stringent cell loss and delay 
requirements and requires the scheduler to provide a quality 
0 of service equivalent, to that of a circuit in a circuit 

switching network. Accordingly, the CBR class connects 
directly to a CBR shaper 2 0 and the output 22 of the CBR 
shaper 20 is connected to the highest priority input of the 
priority element 90. The CBR shaper 20 is essentially a 
;5 large First In First Out (FIFO) buffer which protects the 

network from bursty traffic. The output of the CBR class may 
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include short bursts of traffic which are buffered by the CBR 
shaper and released at a controlled rate so as not to exceed 
downstream bandwidth limitations. 

The sessions belonging to the rtVBR class 14 have 
5 stringent delay requirements but can tolerate certain levels 

of cell loss. Certain guarantees of delay bounds and non- 
zero cell loss ratios are associated with this class. 

Sessions of the nrtVBR class 16 have less stringent cell 
loss requirements than the rtVBR class, but can tolerate 
10 certain levels of delay. This QoS' also provides for 

guaranteed non-zero cell loss objectives. 

Sessions of the ABR class 18 can tolerate certain levels 
of delay and loss. Associated with this QoS are guaranteed 
minimum throughput or minimum cell rates. Additionally, ABR 
15 sources may also adjust their transmission rates from time 

to time as required by a standard flow control algorithm 
implemented at each network node along the path of the 
connection. 

Sessions of the UBR+ class 23 are similar to those of 
2 0 the ABR class 18 but they do not . involve network flow 

control. The UBR class 24 of sessions do not have any 
specific loss, delay, or throughput requirements. 

As an example, the CBR class is typically used for high 
.. quality video, the rtVBR class for voice and video, the 
25 nrtVBR class for low-quality video, the ABR class for data 

with flow control, the UBR+ class for data with no flow 
control and the UBR class for low priority data such as E- 
mail . 

As shown in Fig. 1, for rtVBR sessions 14, a Minimum 
30 Start Time Clocked Fair queuing Plus (MSTCFQ+) scheduler 30 

is used. The MSTCFQ+ scheduler determines the virtual finish 
time of a packet within a session by determining the transfer 
time required for the packet from its length and transfer 
rate, and adds this transfer time to the virtual start time 
35 of the' packet. The virtual start time of the packet is set 

to the system virtual time when the packet was received. The 
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packet with the smallest virtual finish time is then 
scheduled for transfer. The MSTCFQ+ scheduler, due to its 
effective tradeoff between performance and complexity as 
compared to other schedulers, provides the stringent cell 
5 delay requirements required by the rtVBR session. 

A Weighted Round Robin (WRR) scheduler 4 0 is used for 
scheduling the nrtVBR packets since this class does not have 
stringent delay requirements and only expects the network to 
guarantee their specified minimum throughput, while being 
-0 inexpensive to implement. For the same reasons, a second WRR 

scheduler 50 is used to schedule ABR packets 1 and a third WRR 
scheduler 60 is used to schedule UBR+ packets. 

For the UBR class 24 a simple round robin (RR) scheduler 
70 is used since all the UBR sessions should be treated 
- 5 equally. Further, this scheduling hierarchy gives the 

network operator the flexibility to allocate any amount of 
bandwidth to support the UBR connections. RR schedulers are 
also inexpensive to implement. 

At the second level of hierarchy a second MSTCFQ+ 
i0 scheduler 80 is used. This scheduler 80 schedules between 

the first MSTCFQ+ scheduler output 32, the WRR schedulers 
outputs 42, 52 and 62, and the RR scheduler output 72. The 
MSTCFQ+ scheduler is again utilized due to its effective 
tradeoff between performance and complexity as well as being 
inexpensive to implement as compared to schedulers offering 
similar performance. 

The static priority scheduler 90 gives the output 22 
from the CBR shaper 2 0 the highest priority and the rtVBR, 
nrtVBR, ABR, UBR+ and UBR as a group priority below the CBR 
class. The CBR shaper 20 is responsible for per-Virtual 
Circuit (VC) shaping and is work non- conserving in that the 
CBR shaper 20 will allocate bandwidth whether or not it has 
cells pending. As such, the CBR shaper 20 wastes bandwidth 
if no cells are pending. Accordingly, the CBR class is given 
the highest priority while the delay sensitive queues are 
given the next highest priority. 
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Referring to Fig. 2 the method of a particular 
embodiment of the present invention is shown. In the first 
step 110 packets providing a plurality of sessions are 
received. The sessions comprise various types of 

5 transmissions such as data, voice and video and may include 

flow-control . 

The next step, 120 results in the plurality of sessions 
being grouped into classes according to the QoS requirements 
of the respective sessions. Each session is grouped into one 
L0 of the CBR, rtVBR, nrtVBR, ABR, UBR and UBR+ classes. 

The next step 130 provides shaping of t!he CBR class. As 
discussed above, the CBR shaper releases traffic at a 
controlled rate so as to exceed downstream bandwidth 
limitations . 

15 As illustrated in step 140, a first NISTCFQ+ scheduler 

is utilized to schedule an output from the rtVBR sessions. 
As depicted in steps 150, 160 and 170 the nrtVBR sessions, 
the ABR sessions and the UBR+ sessions are scheduled' with 
respective WRR schedulers. As shown in step 180 an RR 

20. scheduler is employed for scheduling an output from UBR 

sessions . 

As illustrated in step 190 a second MSTCFQ+ scheduler 
is employed to schedule an output from among the first 
MSTCFQ+ scheduler, the WRR schedulers and the RR scheduler. 
25 '' The next step 200 provides the CBR shaper output and the 

output of the second level scheduler to a static priority 
scheduler. 

Finally, in step 210 the .CBR shaper output and the 
second level scheduler output are prioritized to provide the 
3 0 hierarchical scheduler output. 

The hierarchical scheduler of the present invention thus 
provides for management of various sessions having various 
requirements and characteristics in a fair, efficient and 
cost effective manner such that multiple sessions can be 
3 5 scheduled in a cell based network such as an ATM network. 
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Having described a preferred embodiment of the invention 
it should be apparent to those of ordinary skill in the art 
that other embodiments and variations of the presently 
disclosed embodiment incorporating these concepts may be 
implemented without departing from the inventive concepts 
herein disclosed. Accordingly, the invention should not be 
viewed as limited to the described embodiments but rather 
should be limited solely by the scope and spirit of the 
appended claims. 
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CLAIMS 

We claim: 

1. A method for scheduling packet transmission in a network 
communication device comprising the steps of: 

receiving a plurality of packets, wherein each of said 
packets is associated with one of a plurality of 
classification types; 

segregating said received packets into a plurality of 
sessions, each of said sessions having at least one of said 
plurality of classification types; 

forwarding said packets for each of said plurality of 
sessions to inputs of a corresponding plurality of first 
level schedulers, each of said schedulers having said input 
for receiving packets within respective sessions and an 
output, and wherein each one of said schedulers employs one 
of a plurality of first level scheduling protocols; 

receiving packets at inputs of a second level scheduler 
from the outputs of at least some of said plurality of first 
level schedulers, wherein said second level scheduler further 
includes an output and is operative in accordance with a 
second level scheduling protocol; 

forwarding packets from the output of said second level 
scheduler to a first input a third level scheduler, and 
forwarding packets from the output of at least one of said 
first level schedulers to a second input of said third level 
scheduler, wherein said third level scheduler has an output 
and is operative in accordance with a third level scheduling 
protocol; and 

forwarding packets from the output, of said third level 
scheduler in accordance with said third level scheduling 
protocol .- 

2. The method of claim 1 wherein said segregating step 
comprises the step of segregating said packets into a 
plurality of sessions wherein each of said sessions is 
associated with one of said classification types, and each 
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of said sessions includes packets associated with at least 
one of a plurality of Quality of Service (Q Q S) levels. 

3 . The method of claim 2 wherein said communication device 
comprises an Asynchronous Transfer Mode (ATM) switch and said 
plurality of Q C S levels comprise Constant Bit Rate (CBR) , 
real time Variable Bit Rate (rtVBR) , non-real time Variable 
Bit Rate (nrtVBR) , Available Bit Rate (ABR) , Unspecified Bit 
Rate + (UBR+) and Unspecified Bit Rate (UBR) Quality of 
Service levels. 

4 . The method of claim 1 wherein each of said first level 
schedulers, said second level scheduler and said third level 
scheduler comprise one of a CBR shaper, a Minimum Start Time 
Clocked Fair Queuing Plus (MSTCFQ+) scheduler, a Weighted 
Round Robin (WRR) scheduler, a Round Robin (RR) scheduler and 
a Static Priority (SP) scheduler. 

5. The method of claim 1 wherein said classification types 
comprise CBR, rtVBR, nrtVBR, ABR , UBR+ , and UBR Q Q S levels. 

6. The method of claim 5 wherein said first level 
schedulers comprise a CBR shaper scheduler, an MSTCFQ+ 
scheduler, a plurality of WRR schedulers and at least one RR 
scheduler . 

7 . The method of claim 6 wherein said second level 
scheduler comprises an MSTCFQ+ scheduler. 

8 . The method of claim 7 wherein said third level scheduler 
comprises a Static Priority scheduler. 

9. The method of claim 8 wherein said CBR shaper receives 
at the input of said shaper packets associated with said CBR 
classification type . 
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10. The method of claim 6 wherein said first level MSTCFQ+ 
scheduler receives at the input of such scheduler, packets 
associated with said rtVBR classification type. 

5 li. The method of claim 6 wherein said plurality of WRR 

schedulers comprise first, second and third WRR schedulers. 

12. The method of claim 11 wherein said, inputs of first, 
second and third WRR schedulers receive at respective inputs 
10 packets corresponding to said nrtVBR, ABR and UBR 

classification types. 

13 . The method of claim 1 wherein said second level 
scheduling protocol comprises one of said first level 
15 scheduling protocols. 

14. The method of claim 10 wherein said second level 
scheduling protocol comprises the same scheduling protocol 
associated with the rtVBR classification type. 

20 

15. The method of claim 1 wherein said plurality of packets 
comprise voice transmissions, video transmissions or data 
transmissions . 

25 16. A method for scheduling packet transmission in a network 

communication device comprising the steps of: 

receiving a plurality of packets, wherein each of said 
packets is associated with one of a plurality of Quality of 
Service (QOS) levels, said Q Q S levels comprising Constant Bit 

30 Rate (CBR) , real time Variable Bit Rate (rtVBR) , non-real 

time Variable Bit Rate (nrtVBR) , Available Bit Rate (ABR), 
Unspecified Bit Rate + (UBR+) and Unspecified Bit Rate (UBR) 
Quality of Service levels; 

segregating said received packets into a plurality of 

35 sessions, each of said sessions having at least one of said 

plurality of Q Q S levels; 
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forwarding said packets for each of said plurality of 
sessions to inputs of a corresponding plurality of first 
level schedulers, each of said schedulers having said input 
for receiving packets within respective sessions and an 
output, and wherein each one of said schedulers employs one 
of a plurality of first level scheduling protocols, said 
first level scheduling protocols comprising a CBR shaper, a 
Minimum Start Time Clocked Fair Queuing Plus (MSTCFQ+) 
scheduler, a Weighted Round .Robin (WRR) scheduler, a Round 
Robin (RR) scheduler and a Static Priority (SP) scheduler; 

receiving packets at inputs of a second' level scheduler 
from the outputs of at least some of said plurality of first 
level, schedulers , wherein said second level scheduler further 
includes an output and is operative in accordance with a 
second level scheduling protocol comprising a MSTCFQ+ 
scheduler ; 

forwarding packets from the output of said second level 
scheduler to a first input a third level scheduler, .and 
forwarding packets from the output of at least one of said 
first level schedulers to a second input of said third level 
scheduler, wherein said third level scheduler has an output 
and is operative in accordance with a third level scheduling 
protocol comprising a Static Priority Scheduler; and 

forwarding packets from the output of said third level 
scheduler in accordance with said third level scheduling 
protocol. 



SUBSTITUTE SHEET (RULE 25) 



WO 98/45976 



1 / 2 



PCT/US98/06252 



CD 
> 



SI 



> 
c 



CO 



0) 
> 




in 



S i S 

Q-O 



a: 9 S 

^ Q-O 



CQ > zj 
> d <D 

C CL O 



I 

e \ CO 

CO i a) 

< <D 3 




CH > =3 

CO ii. <D 



Q-O 



BNSOOCID: <WO 984S976A2_I_> 



WO 98/45976 



PCTYUS98/06252 



2/2 



,110 



Receive packets associated with a plurality of 



sessions 



Group sessions into respective classification types- 
CBR, rtVBR, nrtVBR, ABR, UBR+ and UBR ' 



./ 



,120 



I 



Shape the CBR class with CBR shaper 

I 



Schedule the rtVBR class with a fi rst MSTCFQ+ sr.h«H,.tor" 



Schedule the nrtVBR class with a first WRR scheduler 



[ Schedule the ABR class with a second WRR 



scheduler 



Schedule the UBR+ class with a third WRR scheduler 



| Schedule the UBR class with an RR scheduler 



/1 30 

..140 

,150 

,160 

,170 

,180 

,190 



Schedule the outputs of the first MSTCFQ+ scheduler the 
WRR schedulers and the RR scheduler with a second 
MSTCFQ+ scheduler 



,200 



Provide outputs of the CBR shaper and the second 
MSTCFQ+ scheduler to a Static Priority Scheduler 



,210 



Provide output from Static Priority Scheduler 



Fig. 2 



WORLD INTELLECTUAL PROPERTY ORGANIZATION 
International Bureau 




PCT 

INTERNATIONAL APPLICATION PUBLISHED UNDER THE PATENT COOPERATION TREATY (PCT) 



(51) International Patent Classification 6 : 




(11) International Publication Number: 


WO 98/45976 


H04L 12/28, 12/56, 12/5 4 


A3 


(43) International Publication Date: 


15 October 1998 (15.10.98) 



(21) International Application Number: PCT/US98/06252 

(22) International Filing Date: 27 March 1998 (27.03.98) 



(30) Priority Data: 

60/042,943 



4 April 1997 (04.04.97) 



US 



(71) Applicant: ASCEND COMMUNICATIONS, INC. [US/US]; 1 
Robbins Street, Westford, MA 01886 (US). 

(72) Inventors: GANMUKHI, Mahesh, N.; 1286 Curve Street, 

Carlisle, MA 01741 (US). YANG, Tao; 61 Bogart Crescent, 
Belleville, Ontario 1C8P 5E8 (CA). 

(74) Agents: LEBOVICI, Victor, B. et al.; Weingarten, Schurgin, 
Gagnebin & Hayes LLP, Ten Post Office Square, Boston, 
MA 02109 (US). 



(81) Designated States: AU, CA, JP, European patent (AT, BE, 
CH, DE, DK, ES, FI, FR, GB, GR, IE, IT, LU, MC, NL, 
PT, SE). 



Published 

With international search report. 

(88) Date of publication of the international search report: 

7 January 1999(07.01.99) 



(54) Title: HIERARCHICAL PACKET SCHEDULING METHOD AND APPARATUS 
(57) Abstract 

A method of fairly and efficiently scheduling transmission of a packet from a plurality of sessions onto a network is presented. The 
method includes providing an input having a plurality of sessions, grouping the sessions into a plurality of classes, scheduling the classes 
with first level schedulers associated with one of the classes, scheduling the outputs of some of the first level schedulers with a second 
level scheduler, and prioritizing among the output of the remaining first level scheduler(s) and the output of the second level scheduler to 
provide an hierarchical scheduler output. The scheduler accepts traffic types at its input, and provides an output suitable for scheduling cell 
based traffic such as Asynchronous Transfer Mode (ATM) network traffic. 



BNSOOCID: <WO 9845976A3J_> 



FOR THE PURPOSES OF INFORMATION ONLY 
Codes used to identify States party to the PCT on the front pages of pamphlets publishing international applications under the PCX 



AL Albania 

AM . Armenia 

AT Austria 

AU Australia 

AZ Azerbaijan 

BA Bosnia and Herzegovina 

BB Barbados 

BE Belgium 

BF Burkina Faso 

BG Bulgaria 

BJ Benin 

BR Brazil 

BY Belarus 

CA Canada . 

CF Central African Republic 

CG Congo 

CH Switzerland 

CI Cote d'lvoire 

CM Cameroon 

CN China 

CU Cuba 

CZ Czech Republic 

DE Germany 

DK Denmark 

EE Estonia 



ES 


Spain 


LS 


Lesotho 


FI 


Finland 


LT 


Lithuania 


FR 


France 


LU 


Luxembourg 


GA 


Gabon 


LV 


Latvia 


GB 


United Kingdom 


MC 


Monaco 


GE 


Georgia 


MD 


Republic of Moldova 


GH 


Ghana 


MG 


Madagascar 


GN 


Guinea 


MK 


The former Yugoslav 


GR 


Greece 




Republic of Macedonia 


HU 


Hungary 


ML 


Mali 


IE 


Ireland 


MN 


Mongolia 


IL 


Israel 


MR 


Mauritania 


IS 


Iceland 


MW 


Malawi 


IT 


ItaJy 


MX 


Mexico 


JP 


Japan 


NE 


Niger 


KE 


Kenya 


NL 


Netherlands 


KG 


Kyrgyzstan 


NO 


Norway 


KP 


Democratic People's 


NZ 


New Zealand 




Republic of Korea 


PL 


Poland 


KR 


Republic of Korea 


PT 


Portugal 


KZ 


Kazakstan 


RO 


Romania 


LC 


Saint Lucia 


RU 


Russian Federation 


LI 


Liechtenstein 


SD 


Sudan 


LK 


Sri Lanka 


SE 


Sweden 


LR 


Liberia 


SG 


Singapore 



SI 


Slovenia 


SK 


. Slovakia 


SN 


Senegal 


sz 


Swaziland 


TD 


Chad 


TG 


Togo 


TJ 


Tajikistan 


TM 


Turkmenistan 


TR 


Turkey 


TT 


Trinidad and Tobago 


UA 


Ukraine 


UG 


Uganda 


US 


United States of America 


uz 


Uzbekistan 


VN 


Viet Nam 


YU 


Yugoslavia 


ZW 


Zimbabwe 



INTERNATIONAL SEARCH REPORT 



International application No. 
PCT/US98/06252 



A. CLASSIFICATION OF SUBJECT MATTER 
IPC(6) : H04L 12/28. 12/56, 12/54 
US CL :Please See Extra Sheet. 

According to I nternational Patent Classification (IPC) or to both national classification and IPC 

B. FIELDS SEARCHED 



M 



inimum documentation searched (classification system foUowcd by classification symbols) 
U.S. : 370/411, 412, 415, 416, 417, 418, 428, 429; 395/200.57, 200.58, 200.59 



Documentation searched other than minimum documentation to the extent that such docu 



ments arc included in the fields searched 



Electronic data base consulted during the international search (name of data base and, whe 



re practicable, search terms used) 



c * DOCUMENTS CONSIDERED TO BE RELEVANT 



Category 



A 
A 

A, P 
A 

A, P 
A 



Citation of document, with indication, where appropriate, of the relevant 



passages 



US 5,499,238 A (SHON et al) 12 March 1996 
US 5,231,633 A (HLUCHYJ et al) 27 July 1993 
US 5,629,933 A (DELP et al) 13 May 1997 
US 5,455,825 A (LAUER et al) 3 October 1995 
US 5,748,614 A (WALLMEIER) 5 May 1998 
US 5,463,620 A (SRIRAM) 31 October 1995 



Relevant to claim No. 



□ Further document* are listed in the continuation of Box C. Q See patent famijy annex. 



1-16 

1-16 
1-16 
1-16 
1-16 
1-16 



.p. 



Special categoric* of cited document!: 

dc^ummdefming the general Mate of the an which a not cooaidered 
to be of partacular relevance 

earlier document published oo or after ibe mleraationaj filing dale 

document which may throw doubu on priority claim(a) or which a 
cited to eatabliah the publication date of another citation or other 
apectal reaaon (u epeetried) 

document referring to an oral diacloaure, uae. exhibition or other 
means 



•x- 



documeni published prior to the mtertulionai filinjr dale but later than 
the priority date claimed 



Date of the actual completion of the international search 



later document published after the international filing date or priority 
dale todDXKm coo/bct with the application but cited to understand the 
pnnctpie or theory underlying the invention 

document of pabular relevance; the claimed invention cannot be 
wxuidered novel or cannot be considered to involve an inventive step 
when the document is taken aione 

document of particular relevance; the claimed invention cannot be 
couriered to involve an inventive step when the document is 
combined with oac or more other such documents, such combination 
being-obvious to ■ person skilled in the art 

document member of the same patent family 



25 JUNE 1998 



Name and mailing address of the ISA/US 
Commusioner of Patents and Trademarks 
Box PCT 

Washington, D.C. 20231 
Facsimile- No. (703) 305-3230 



Form PCT/1SA/210 (second sheet)(July 1992)* 



Date of mailing of the international search report 



2 8 SEP 1938 



Authorized officer 

CHI PHAM 
Telephone No. (703) 308-8848 




BNSDOC1D: <WO 9845976A3J. 



INTERNATIONAL SEARCH REPORT 



international application No. 
PCT/US98/06252 



A. CLASSIFICATION OF SUBJECT MATTER: 
US CL : 

370/411, 412, 415, 416, 417, 418, 428, 429; 395/200.57, 200.58, 200.59 



Form PCT/1SA/210 (extra shcct)(July 1992)* 



: <WO 9845976A3J_> 



